03,"02/05 WED 17: So FAX 4057208331 BST&Z !?]004 

42390P 10807 PATENT 



AMENDMENTS TO THE CLAIMS 

1. (Original) A method comprising: 

trapping, by a processor, a change in execution among schedulable entities; and 
tracking an execution of a schedulable entity that is being switched in for 
execution as a result of the change in execution. 

2. (Original) The method of claim 1 , wherein the tracking is performed by a 
privileged entity and further comprising: 

calculating, by the privileged entity, an estimated resource requirement for the 
schedulable entity that is being switched in for execution from the tracking of a previous 
execution of the schedulable entity; and 

scheduling, by the privileged entity, the schedulable entity that is being switched 
in for execution according to its estimated resource requirement. 

3. (Original) The method of claim 2, wherein the privileged entity is a virtual 
machine monitor and the schedulable entities are selected from the group consisting of 
processes, threads, operating systems, virtual machines, and child virtual machine 
monitors. 

4. (Currently Amended) The method of claim 2, wherein the virtual machin e 
monitor privileged entity comprises: 
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an idle detector to receive notice from the processor of the change in execution 
and to derive a measured value for a schedulable entity that is being switched out of 
execution; 

a proportional integral derivative (PID) controller logically coupled to the idle 
detector to receive the measured value and to calculate the estimated resource 
requirement required by the schedulable entity that is being switched out of execution;, 
and 

a scheduler logically coupled to the PID controller to receive the estimated 
resource requirement and to determine a schedule of execution for the schedulable entity 
that is being switched out of execution. 



5. (Original) The method of claim 2, wherein calculating an estimated resource 
requirement comprises: 

assigning an initial value as the estimated resource requirement for the 
schedulable entity that is being switched in for execution; 

reducing the estimated resource requirement for the schedulable entity if the 
schedulable entity completes execution before the estimated resource requirement is 
exhausted; and 

increasing the estimated resource requirement for the schedulable entity if the 
schedulable entity does not complete execution before the estimated resource requirement 
is exhausted. 
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6. (Original) The method of claim 2 further comprising: 
initiating, by the privileged entity, the change in execution. 

7. (Original) The method of claim 6, wherein the tracking of the execution is 
perforated as part of the change in execution initiated by the privileged entity. 

8. (Original) The method of claim 2 further comprising: 

initiating, by the processor, the change in execution if the change in execution is 
being requested by the privileged entity. 

9. (Original) The method of claim 1, v/herein trapping a change in execution 
comprises: 

detecting an instruction to change a state register that identifies a schedulable 

entity. 

1 0. (Original) The method of claim 9 further comprising: 

comparing, by the processor, the state register that identifies the schedulable 
entity being switched in for execution with a state match register that identifies a 
schedulable entity that is to be tracked, wherein the schedulable entity being switched 
into execution is tracked by the processor if the state register and the state match register 
match. 
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1 1 . (Original) The method of claim 1 3 wherein trapping a change in execution 
comprises: 

detecting an instruction to change between privileged and non-privileged modes. 

12. (Original) The method of claim 1, wherein the schedulable entities are selected 
from the group consisting of operating system processes, operating system threads, 
virtual machines, and instruction streams to be executed by the processor. 

1 3 . (Original) A machine-readable medium providing instructions, which when 
executed by a machine, causes the machine to perform operations comprising: 

trapping, by a processor, a change in execution among schedulable entities; and 
tracking an execution of a schedulable entity that is being switched in for 
execution as a result of the change in execution. 



14. (Original) The machine-readable medium of claim 1 3 s wherein the tracking is 
performed by a privileged entity and further comprising: 

calculating, by the privileged entity, an estimated resource requirement for the 
schedulable entity that is being switched in for execution based on the tracking of a 
previous execution of the schedulable entity; and 

scheduling, by the privileged entity, the schedulable entity that is being switched 
in for execution according to the estimated resource requirement. 
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15. (Original) The machine-readable medium of claim 14, wherein the privileged 
entity is a virtual machine monitor and the schedulable entities are selected from the 
group consisting of processes, threads, operating systems, virtual machines, and child 
virtual machine monitors. 

16. (Original) The machine-readable medium of claim 14, wherein the virtual 
machine monitor comprises: 

an idle detector to receive notice from the processor of the change in execution 
and to derive a measured value for a schedulable entity that is being switched out of 
execution; 

a proportional integral derivative (PID) controller logically coupled to the idle 
detector to receive the measured value and to calculate the estimated resource 
requirement required by the schedulable entity that is being switched out of execution; 
and 

a scheduler logically coupled to the PID controller to receive the estimated 
resource requirement and to deteimine a schedule of execution for the schedulable entity 
that is being switched out of execution. 

17. (Original) The machine-readable medium of claim 14, wherein calculating an 
estimated resource requirement comprises: 

assigning an initial value as the estimated resource requirement for the 
schedulable entity that is being switched in for execution; 
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reducing the estimated resource requirement for the schedulable entity if the 
schedulabJe entity completes execution before the estimated resource requirement is 
exhausted; and 

increasing the estimated resource requirement for the schedulable entity if the 
schedulable entity does not complete execution before the estimated resource requirement 
is exhausted. 

18. (Original) The machine-readable medium of claim 14 further comprising: 
initiating, by the privileged entity, the change in execution. 

19- (Original) The machine-readable medium of claim 1 8, wherein the tracking of 
the execution is performed as part of the change in execution initiated by the privileged 
entity. 

20. (Original) The machine-readable medium of claim 14 further comprising: 
initiating, by the processor, the change in execution if the change in execution is 

being requested by the privileged entity. 

2 1 . (Original) The machine-readable medium of claim 1 3, wherein trapping a change 
in execution comprises: 

detecting an instruction to change a state register that identifies a schedulable 

entity. 
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22. (Original) The machine-readable medium of claim 1 3 further comprising: 
comparing, by the processor, the state register that identifies the schedulable 

entity being switched in for execution with a state match register that identifies a 
schedulable entity that is to be tracked, wherein the schedulable entity being switched 
into execution is tracked by the processor if the state register and the state match register 
match. 

23. (Original) The machine-readable medium of claim 13, wherein trapping a change 
in execution comprises: 

detecting an instruction to change between privileged and non-privileged modes. 

24. (Original) The machine-readable medium of claim 13, wherein the schedulable 
entities are selected from the group consisting of operating system processes, operating 
system threads, virtual machines, and instruction streams to be executed by the processor. 

25. (Original) An apparatus comprising: 
a memory; 

a processing unit coupled to the memory and configured to trap to a privileged 
entity, a change in execution among schedulable entities; and 

the privileged entity executed from the memory to cause the processing unit to 
track an execution of a schedulable entity that is being switched in for execution as a 
result of the change in execution* 
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26, (OriginaJ) The apparatus of claim 25, wherein the privileged entity further causes 
the processing unit to calculate an estimated resource requirement for the schedulable 
entity that is being switched in for execution based on the tracking of a previous 
execution of the schedulable entity and to schedule the schedulable entity that is being 
switched in for execution according to the estimated resource requirement. 



27. (Original) The apparatus of claim 26, wherein the privileged entity i$ a virtual 
machine monitor and the schedulable entities are selected from the group consisting of 
processes, threads, operating systems, virtual machines, and child virtual machine 
monitors. 



28. (Original) The apparatus of claim 27, wherein the virtual machine monitor 
comprises: 

an idle detector to receive notice from the processing unit of the change in 
execution and to derive a measured value for a schedulable entity that is being switched 
out of execution; 

a proportional integral derivative (PID) controller logically coupled to the idle 
detector to receive the measured value and to calculate the estimated resource 
requirement for the schedulable entity that is being switched out of execution; and 

a scheduler logically coupled to the PID controller to receive the estimated 
resource requirement and to determine a schedule of execution for the schedulable entity 
that is being switched out of execution. 
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29. (Original) The apparatus of claim 26, wherein the privileged entity further causes 
the processing unit to calculate an estimated machine resource requirement by: 
assigning an initial value as the estimated resource requirement for the 
schedulable entity; 

reducing the estimated resource requirement for the schedulable entity if the 
schedulable entity completes execution before the estimated resource requirement is 
exhausted; and 

increasing the estimated resource requirement for the schedulable entity if the 
schedulable entity does not complete execution before the estimated resource requirement 
is exhausted. 



30. (Original) The apparatus of claim 25, wherein the processing unit is further 
configured to trap a change in execution by detecting an instruction to change a state 
register that identifies a schedulable entity. 



3 1 . (Original) The apparatus of claim 25, wherein the processing unit is further 
configured to trap a change in execution by detecting an instruction to change between 
privilege and non-privilege modes. 



32. (Original) The apparatus of claim 25, wherein the privileged entity further causes 
the processing unit to initiate the change in execution. 
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33. (Original) The apparatus of claim 32, wherein the privileged entity further causes 
the processor to track the execution as part of the change in execution initiated by the 
privileged entity. 

34. (Original) The apparatus of claim 25, wherein the processing unit is further 
configured to initiate the change in execution if the change in execution is being 
requested by the privileged entity. 

35. (Original) An apparatus comprising: 

a processing unit configured to trap a change in execution among schedulable 
entities, to compare a state register that identifies the schedulable entity being switched in 
for execution with a state match register that identifies a schedulable entity that is to be 
tracked, and to track the schedulable entity being switched into execution if the state 
register and the state match register match. 

36. (Original) The apparatus of claim 35, wherein the schedulable entities are 
selected from the group consisting of operating system processes, operating system 
threads, virtual machines, and instruction streams to be executed by the processing unit. 
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